# **Vivado IP Flow Demo Script**

## Introduction

This demonstration introduces the IP flow, including:

- Upgrading IP
- Customizing IP
- · Generating output products
- Instantiating IP
- Identifying the difference between the out-of-context flow (OOC) flow and global synthesis flow

#### **Preparation:**

• Required files: \$TRAINING PATH/IP Flow/demo/KCU105/verilog

Required hardware: NoneSupporting materials: None

## **Vivado IP Flow**

| Action with Description                                                                                                                                                                                                                                          | Point of Emphasis and Key Takeaway                                                                                                                                                                                                                                                                                                |
|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <ul> <li>Launch the Vivado™ Design Suite.</li> <li>Unzip the project using the Tcl Console:         exec unzip \$::env(TRAINING_PATH)/         IP_Flow/demo/KCU105/verilog.zip         -d \$::env(TRAINING_PATH)/         IP_Flow/demo/KCU105/verilog</li> </ul> | <ul> <li>The Getting Started page provides links to:</li> <li>Create a new project</li> <li>Open an existing project</li> <li>Open example projects</li> <li>Manage IP</li> <li>Open the hardware manager</li> <li>Visit the Vivado Store</li> <li>View documentation and QuickTake videos for the Vivado Design Suite</li> </ul> |
| Open the wave_gen.xpr project from the following directory:  \$TRAINING_PATH/IP_Flow/demo/KCU105/verilog                                                                                                                                                         | <ul> <li>You can easily open an existing Vivado<br/>IDE project via the Getting Started page.</li> </ul>                                                                                                                                                                                                                          |

| Action with Description |                                                                                                                                   | Point of Emphasis and Key Takeaway |                                                                                                                                                                                                                                                                                                                                       |  |
|-------------------------|-----------------------------------------------------------------------------------------------------------------------------------|------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| •                       | Go to IP Sources in the Sources window, right-click clk_core, and select Report IP Status.                                        | •                                  | The IP status tab shows the device part of the IP targeted, under <i>Current Part</i> .  In this demo, the <i>clk_core</i> IP is targeted to a Kintex <sup>™</sup> 7 series device and the project is targeted to a Kintex UltraScale <sup>™</sup> device.  The change log for the upgraded IP can also be viewed from IP Status tab. |  |
| •                       | Right-click <b>clk_core</b> from the IP Sources tab and select <b>Upgrade IP</b> .                                                | •                                  | The IP Status tab after upgrading the IP shows that the <i>clk_core</i> IP is up-to-date.                                                                                                                                                                                                                                             |  |
| •                       | Right-click <b>clk_core</b> from the IP Sources tab and select <b>Generate Output Products.</b>                                   | •                                  | For this demo, you do not need to enable the core container features for this IP.                                                                                                                                                                                                                                                     |  |
| •                       | Click <b>Generate</b> in the dialog box to generate the output products for clk_core.                                             |                                    |                                                                                                                                                                                                                                                                                                                                       |  |
| •                       | Click <b>OK</b> in the Generate Output Products dialog box.                                                                       |                                    |                                                                                                                                                                                                                                                                                                                                       |  |
| •                       | Rerun the IP Status report from <b>Reports</b> > <b>Report IP Status</b> to notice that the <i>clk_core</i> IP is up-to-date now. |                                    |                                                                                                                                                                                                                                                                                                                                       |  |
| •                       | Select <b>IP Catalog</b> from the Flow Navigator.                                                                                 | •                                  | The Vivado IP catalog provides consistent, easy access to our IP, including building blocks, wizards, connectivity, DSP, embedded, AXI infrastructure, and video IP from a single common repository regardless of the end application being developed.                                                                                |  |
|                         |                                                                                                                                   | •                                  | Note that only one version of IP (i.e., the latest version of IP) will be available in the IP catalog.                                                                                                                                                                                                                                |  |

| Action with Description                                                                                                                                                                                        | Point of Emphasis and Key Takeaway                                                                                                                                             |
|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Search for and select FIFO Generator from the IP catalog.                                                                                                                                                      | The IP catalog contains categories of IP that you can filter and search.                                                                                                       |
|                                                                                                                                                                                                                | You can work with the IP catalog in a variety of ways. You can search using keywords in the search box or browse through the catalog in the various categories.                |
|                                                                                                                                                                                                                | Selecting IP will list all the details of the selected IP:                                                                                                                     |
|                                                                                                                                                                                                                | <ul> <li>Name, version, types of supported<br/>interfaces, brief description of IP, IP<br/>status, etc.</li> </ul>                                                             |
| Double-click to customize the FIFO     Generator IP with the following     parameters:                                                                                                                         | The selected IP can be customized by right-clicking and selecting Customize IP or double -click the IP.                                                                        |
| <ul> <li>Basic tab &gt; Component Name:         char_fifo</li> <li>FIFO Implementation: Independent         Clocks Built-in FIFO</li> </ul>                                                                    | In the Summary tab of the IP     Customization dialog box you can verify     that the information is correct and then     generate the IP.                                     |
| <ul> <li>Native ports tab &gt; Read Mode: First Word Fall Through</li> <li>Write width: 8</li> <li>Write depth: 2048</li> </ul>                                                                                | Once the customization is done, the<br>Generate Output Products dialog box<br>opens.                                                                                           |
| <ul> <li>Click <b>OK</b> and click <b>Generate</b> in the dialog box to generate the output products with the default settings (OOC flow).</li> <li>Click <b>OK</b> if the Generate Output Products</li> </ul> | By default, the <b>Synthesized Checkpoint</b> (.dcp) is generated, and an Out-of-Context Module Run for the <i>char_fifo</i> IP is added to the Design Runs window.            |
| dialog box prompts.                                                                                                                                                                                            | The new run is created and launched to synthesize the IP.                                                                                                                      |
|                                                                                                                                                                                                                | When the entire design is synthesized, an HDL stub module is provided in the DCP, which causes a black box to be inferred for the IP.                                          |
|                                                                                                                                                                                                                | This OOC flow reduces synthesis run times because the IP is synthesized only once. If the top-level design is changed and has to be synthesized, the IP is not re-synthesized. |
|                                                                                                                                                                                                                | The synthesis log file can be viewed from<br>the properties window by selecting the<br>created IP run from the Design Runs<br>window.                                          |

#### **Action with Description**

#### Point of Emphasis and Key Takeaway

In the Log table tab next to TCL Console tab, select the **char\_fifo\_synth\_1** and see the log file.



Select the **IP Sources** tab to examine the output products that are generated.



- The IP Sources window shows the generated output products.
- By default, the IP will generate:
  - Instantiation template
  - Synthesis files
    - Constraints files associated with synthesis
  - Simulation files
    - Simulation sources associated with
  - Change log
  - Design checkpoint (.dcp)
    - Synthesizes the IP and generates the DCP file in OOC mode
  - Simulation netlist and stub files
- View the instantiation template that is generated for char fifo.
- Since it is already been instantiated, you can view it in the Hierarchy tab under the top-level file (wave\_gen).
- After the IP is generated, if the IP is not instantiated in the design it will be added at the same level as the top-level wave gen module in the Hierarchy tab.
- The IP has already been instantiated in the design. To view the instantiation, open the wave\_gen.v file in the text editor and observe lines 338 to 350.
- Notice that the Hierarchy, Libraries, and Compile Order tabs are updated to indicate that the IP has been instantiated into the design.

|   | Action with Description                                                                                                                                                                                                                                                                                                                                                                                  |   | Point of Emphasis and Key Takeaway                                                                                                                                                        |
|---|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| • | Observe the directory structure of the generated output products for the IP.  • Browse to the \$TRAINING_PATH/ IP_Flow/demo/KCU105/verilog/ wave_gen.srcs/sources_1/ip directory.  • Notice that there is one directory for each IP.                                                                                                                                                                     | • | The <i>clk_core</i> directory contains the output products for the <i>clk_core</i> IP.  The <i>char_fifo</i> directory contains the output products for the <i>char_fifo</i> IP.          |
| • | <ul> <li>Examine the output products for the char_fifo IP in the IP Sources tab of the Sources view.</li> <li>Select the IP Sources tab in the Sources window.</li> <li>Expand the char_fifo and clk_core folders and observe that the outputs products for both IPs are the same.</li> </ul>                                                                                                            | • | Within the Vivado IDE Sources view, the two IP appear the same, both listing the output products, all of which can be opened for viewing from within the Vivado IDE.                      |
| • | <ul> <li>Generate the output products for char_fifo by using the global synthesis flow.</li> <li>Right-click char_fifo in the IP Sources window and select Generate Output Products.</li> <li>Select the Global option in the Synthesis Options section and click Generate in the Generate the output products section.</li> <li>Click OK if the Generate Output Products dialog box appears.</li> </ul> | • | Note that new design run for <i>char_fifo</i> is not created as in the OOC flow.  Now, the <i>char_fifo</i> IP output products will be generated while synthesizing the top-level design. |
| • | Synthesize the design.                                                                                                                                                                                                                                                                                                                                                                                   | • | The char_fifo IP gets synthesized along with the top-level design.                                                                                                                        |

|   | Action with Description                                                                                                                      |   | Point of Emphasis and Key Takeaway                                                         |
|---|----------------------------------------------------------------------------------------------------------------------------------------------|---|--------------------------------------------------------------------------------------------|
| • | Right-click the <b>char_fifo</b> IP and select <b>Remove File from Project</b> to delete the <i>char_fifo</i> IP from the IP Sources window. | • | IP can be created and customized by using Tcl commands such as create_ip and set_property. |
|   | <ul> <li>Also, make sure that the IP files are<br/>removed from the project directory.</li> </ul>                                            | • | The generate_target command is used to generate output products.                           |
| • | Run a Tcl script to generate the <i>char_fifo</i> IP.                                                                                        |   |                                                                                            |
|   | <ul> <li>Run the Tcl script from the Tcl Console<br/>by using the following command:</li> </ul>                                              |   |                                                                                            |
|   | <pre>source \$::env(TRAINING_PATH)/ IP_Flow/demo/KCU105/verilog/ char_fifo_run.tcl</pre>                                                     |   |                                                                                            |
|   | • View the Tcl script and output products generated for <i>char_fifo</i> .                                                                   |   |                                                                                            |
| • | Select <b>File &gt; Exit</b> to close the Vivado Design Suite.                                                                               |   |                                                                                            |

# **Summary**

This demonstration showed you the IP flow, use of the core container feature, and the difference between out-of-context (OOC) and global synthesis flow.

#### References:

- Supporting materials
  - Vivado Design Suite User Guide: Design with IP (UG896)
  - Using Core Containers for IP Quick Take video www.xilinx.com/training/vivado/using-core-containers-for-ip.htm